Encapsulates the DATE data type that is used in OLE automation.
It is one of the possible types for the VARIANT data type of OLE automation. A COleDateTime value represents an absolute date and time value. The DATE type is implemented as a floating-point value. Days are measured from December 30, 1899, at midnight. The COleDateTime class handles dates from January 1, 100, through December 31, 9999. The COleDateTime class uses the Gregorian calendar; it does not support Julian dates. COleDateTime ignores Daylight Saving Time. This type is also used to represent date-only or time-only values. By convention, the date 0 (December 30, 1899) is used for time-only values and the time 00:00 (midnight) is used for date-only values.
Caution: Note that although day values become negative before midnight on December 30, 1899, time-of-day values do not. For example, 6:00 AM is always represented by a fractional value 0.25 regardless of whether the integer representing the day is positive (after December 30, 1899) or negative (before December 30, 1899). This means that a simple floating point comparison would erroneously sort a COleDateTime representing 6:00 AM on 12/29/1899 as later than one representing 7:00 AM on the same day.
Include file: COleDateTime.inc
| Name | Description |
|---|---|
| Constructors | Create new COleDateTime objects initialized to the specified value. |
| CAST Operator | Returns the COleDateTime value as a long integer. |
| LET Operator | Assigns a value to a COleDateTime object. |
| Operators | Adds, subtracts or compares COleDateTime objects. |
| Format | Converts a COleDateTime object to a string. |
| Format (Overload) | Converts a COleDateTime object to a string. |
| GetAsDBTIMESTAMP | Returns the date/time the of this COleDateTime object as a DBTIMESTAMP data structure. |
| GetAsSystemTime | Returns the date/time the of this COleDateTime object as a SYSTEMTIME data structure. |
| GetAsUdate | Returns the date/time the of this COleDateTime object as a UDATE structure. |
| GetCurrentTime | Returns the current date/time value in local time. |
| GetDay | Gets the day represented by this date/time value. |
| GetDayOfWeek | Gets the day of the week represented by this date/time value. |
| GetDayOfYear | Gets the day of the year represented by this date/time value. |
| GetHour | Gets the hour represented by this date/time value. |
| GetLocalTime | Returns the current date/time value in local time. |
| GetMinute | Gets the minute represented by this date/time value. |
| GetMonth | Gets the month represented by this date/time value. |
| GetSecond | Gets the second represented by this date/time value. |
| GetStatus | Gets the status (validity) of a given COleDateTime object. |
| GetSystemTime | Returns the current date/time value in Coordinated Universal Time (UTC). |
| GetYear | Gets the year represented by this date/time value. |
| SetDate | Sets the date of this COleDateTime object. |
| SetDateTime | Sets the date and time of this COleDateTime object. |
| SetStatus | Sets the status (validity) of a given COleDateTime object. |
| SetTime | Sets the time of this COleDateTime object. |
| Name | Description |
|---|---|
| Constructors | Create new COleDateTimeSpan objects initialized to the specified value. |
| CAST Operator | Returns the COleDateTimeSpan value as a long integer. |
| LET Operator | Assigns a value to a COleDateTimeSpan object. |
| Operators | Adds, subtracts or compares COleDateTimeSpan objects. |
| GetDays | Retrieves the day portion of this date/time-span value. |
| GetHours | Retrieves the hour portion of this date/time-span value. |
| GetMinutes | Retrieves the minutes portion of this date/time-span value. |
| GetSeconds | Retrieves the seconds portion of this date/time-span value. |
| GetStatus | Gets the status (validity) of a given COleDateTimeSpan object. |
| GetTotalDays | Retrieves this date/time-span value expressed in days. |
| GetTotalHours | Retrieves this date/time-span value expressed in hours. |
| GetTotalMinutes | Retrieves this date/time-span value expressed in minutes. |
| GetTotalSeconds | Retrieves this date/time-span value expressed in seconds. |
| SetDateTimeSpan | Sets the date and time of this COleDateTimeSpan object. |
| SetStatus | Sets the status (validity) of a given COleDateTimeSpan object. |
Create new COleDateTime objects initialized to the specified value.
CONSTRUCTOR COleDateTime
CONSTRUCTOR COleDateTime (BYREF dateSrc AS COleDateTime)
CONSTRUCTOR COleDateTime (BYREF varSrc AS VARIANT)
CONSTRUCTOR COleDateTime (BYVAL dtSrc AS DATE_)
CONSTRUCTOR COleDateTime (BYVAL timeSrc AS LONGLONG)
CONSTRUCTOR COleDateTime (BYREF systimeSrc AS SYSTEMTIME)
CONSTRUCTOR COleDateTime (BYREF filetimeSrc AS FILETIME)
CONSTRUCTOR COleDateTime (BYVAL wDosDate AS DWORD, BYVAL wDosTime AS WORD)
CONSTRUCTOR COleDateTime (BYREF dbts AS DBTIMESTAMP)
CONSTRUCTOR COleDateTime (BYREF ud AS UDATE)
CONSTRUCTOR COleDateTime (BYVAL nYear AS WORD, BYVAL nMonth AS WORD, BYVAL nDay AS WORD, _
BYVAL nHour AS WORD, BYVAL nMin AS WORD, BYVAL nSec AS WORD)
CONSTRUCTOR COleDateTime (BYREF wsz AS WSTRING, BYVAL dwFlags AS DWORD = 0, _
BYVAL lcid AS LCID = LANG_USER_DEFAULT)
| Parameter | Description |
|---|---|
| dateSrc | An existing COleDateTime object to be copied into the new COleDateTime object. |
| varSrc | An existing VARIANT data structure to be converted to a date/time value (VT_DATE) and copied into the new COleDateTime object. |
| dtSrc | A date/time ( DATE) value to be copied into the new COleDateTime object. |
| timeSrc | A LongInt value to be converted to a date/time value and copied into the new COleDateTime object. |
| systimeSrc | A SYSTEMTIME structure to be converted to a date/time value and copied into the new COleDateTime object. |
| filetimeSrc | A FILETIME structure to be converted to a date/time value and copied into the new COleDateTime object. Note that FILETIME uses Universal Coordinated Time (UTC), so if you pass a local time in the structure, your results will be incorrect. See File Times in the Windows SDK for more information. |
| nYear / nMonth / nDay / nHour / nMin / nSec | Indicate the date and time values to be copied into the new COleDateTime object. |
| wDosDate / wDosTime | MS-DOS date and time values to be converted to a date/time value and copied into the new COleDateTime object. |
| dbts | A reference to a DBTimeStamp structure containing the current local time. |
| ud | The UDATE value is converted and copied into this COleDateTime object. If the conversion is successful, the status of this object is set to valid; if unsuccessful, it is set to invalid. A UDATE structure represents an "unpacked" date. See the function VarDateFromUdate for more details. |
| wsz | A null-terminated unicode string which is to be parsed. This parameter can take a variety of formats. For example, the following strings contain acceptable date/time formats: "25 January 1996" "8:30:00" "20:30:00" "January 25, 1996 8:30:00" "8:30:00 Jan. 25, 1996" "1/25/1996 8:30:00" // always specify the full year, even in a 'short date' format. Note that the locale ID will also affect whether the string format is acceptable for conversion to a date/time value. In the case of VAR_DATEVALUEONLY, the time value is set to time 0, or midnight. In the case of VAR_TIMEVALUEONLY, the date value is set to date 0, meaning 30 December 1899. |
| dwFlags | Indicates flags for locale settings and parsing. LOCALE_NOUSEROVERRIDE Use the system default locale settings, rather than custom user settings. VAR_TIMEVALUEONLY Ignore the date portion during parsing. VAR_DATEVALUEONLY Ignore the time portion during parsing. |
| lcid | Indicates locale ID to use for the conversion. Default value: LANG_USER_DEFAULT. |
The status of the new COleDateTime object is set to valid.
Returns the underlying DATE value from this COleDateTime object.
OPERATOR CAST () AS DATE_
Assigns a value to a COleDateTime object.
OPERATOR LET (BYREF dateSrc AS COleDateTime)
OPERATOR LET (BYREF varSrc AS VARIANT)
OPERATOR LET (BYVAL dtSrc AS DATE_)
OPERATOR LET (BYVAL timeSrc AS LONGLONG)
OPERATOR LET (BYREF systimeSrc AS SYSTEMTIME)
OPERATOR LET (BYREF filetimeSrc AS FILETIME)
OPERATOR LET (BYREF dbts AS DBTIMESTAMP)
OPERATOR LET (BYREF ud AS UDATE)
OPERATOR LET (BYREF wsz AS WSTRING)
| Parameter | Description |
|---|---|
| dateSrc | An existing COleDateTime object to be copied into the new COleDateTime object. |
| varSrc | An existing VARIANT data structure to be converted to a date/time value (VT_DATE) and copied into the new COleDateTime object. |
| dtSrc | A date/time ( DATE) value to be copied into the new COleDateTime object. |
| timeSrc | A LongInt value to be converted to a date/time value and copied into the new COleDateTime object. |
| systimeSrc | A SYSTEMTIME structure to be converted to a date/time value and copied into the new COleDateTime object. |
| filetimeSrc | A FILETIME structure to be converted to a date/time value and copied into the new COleDateTime object. Note that FILETIME uses Universal Coordinated Time (UTC), so if you pass a local time in the structure, your results will be incorrect. See File Times in the Windows SDK for more information. |
| dbts | A reference to a DBTimeStamp structure containing the current local time. |
| ud | The UDATE value is converted and copied into this COleDateTime object. If the conversion is successful, the status of this object is set to valid; if unsuccessful, it is set to invalid. A UDATE structure represents an "unpacked" date. See the function VarDateFromUdate for more details. |
| wsz | A null-terminated unicode string which is to be parsed. This parameter can take a variety of formats. For example, the following strings contain acceptable date/time formats: "25 January 1996" "8:30:00" "20:30:00" "January 25, 1996 8:30:00" "8:30:00 Jan. 25, 1996" "1/25/1996 8:30:00" // always specify the full year, even in a 'short date' format. Note that the locale ID will also affect whether the string format is acceptable for conversion to a date/time value. In the case of VAR_DATEVALUEONLY, the time value is set to time 0, or midnight. In the case of VAR_TIMEVALUEONLY, the date value is set to date 0, meaning 30 December 1899. |
Adds, subtracts or compares COleDateTime objects.
OPERATOR + (BYREF dt AS COleDateTime, BYREF dateSpan AS COleDateTimeSpan) AS COleDateTime
OPERATOR - (BYREF dt1 AS COleDateTime, BYREF dt2 AS COleDateTime) AS COleDateTimeSpan
OPERATOR - (BYREF dt AS COleDateTime, BYREF dateSpan AS COleDateTimeSpan) AS COleDateTime
OPERATOR += (BYREF dateSpan AS COleDateTimeSpan)
OPERATOR -= (BYREF dateSpan AS COleDateTimeSpan)
OPERATOR = (BYREF dt1 AS COleDateTime, BYREF dt2 AS COleDateTime) AS BOOLEAN
OPERATOR <> (BYREF dt1 AS COleDateTime, BYREF dt2 AS COleDateTime) AS BOOLEAN
OPERATOR < (BYREF dt1 AS COleDateTime, BYREF dt2 AS COleDateTime) AS BOOLEAN
OPERATOR > (BYREF dt1 AS COleDateTime, BYREF dt2 AS COleDateTime) AS BOOLEAN
OPERATOR <= (BYREF dt1 AS COleDateTime, BYREF dt2 AS COleDateTime) AS BOOLEAN
OPERATOR >= (BYREF dt1 AS COleDateTime, BYREF dt2 AS COleDateTime) AS BOOLEAN
Converts a COleDateTime to a formatted string.
FUNCTION Format (BYREF wszFmt AS WSTRING) AS CWSTR
| Parameter | Description |
|---|---|
| wszFmt | A format string which contains special formatting codes that are preceded by a percent sign (%). |
Formatting codes:
| Code | Meaning |
|---|---|
| %a | Abbreviated weekday name |
| %A | Full weekday name |
| %b | Abbreviated month name |
| %B | Full month name |
| %c | Date and time representation appropriate for locale |
| %d | Day of month as decimal number (01 – 31) |
| %H | Hour in 24-hour format (00 – 23) |
| %I | Hour in 12-hour format (01 – 12) |
| %j | Day of year as decimal number (001 – 366) |
| %m | Month as decimal number (01 – 12) |
| %M | Minute as decimal number (00 – 59) |
| %p | Current locale's A.M./P.M. indicator for 12-hour clock |
| %S | Second as decimal number (00 – 59) |
| %U | Week of year as decimal number, with Sunday as first day of week (00 – 53) |
| %w | Weekday as decimal number (0 – 6; Sunday is 0) |
| %W | Week of year as decimal number, with Monday as first day of week (00 – 53) |
| %x | Date representation for current locale |
| %X | Time representation for current locale |
| %y | Year without century, as decimal number (00 – 99) |
| %Y | Year with century, as decimal number |
| %z, %Z | Either the time-zone name or time zone abbreviation, depending on registry settings; no characters if time zone is unknown |
| %% | Percent sign |
The # flag may prefix any formatting code. In that case, the meaning of the format code is changed as follows.
Converts a COleDateTime to a formatted string.
FUNCTION Format (BYVAL dwFlags AS DWORD = 0, BYVAL lcid AS LCID = LANG_USER_DEFAULT) AS CWSTR
| Parameter | Description |
|---|---|
| dwFlags | One or more of the following flags. |
| lcid | The locale identifier. Default value: LANG_USER_DEFAULT. |
| Flag | Meaning |
|---|---|
| LOCALE_NOUSEROVERRIDE | Uses the system default locale settings, rather than custom locale settings. |
| VAR_CALENDAR_HIJRI | If set then the Hijri calendar is used. Otherwise the calendar set in the control panel is used. |
| VAR_CALENDAR_THAI | If set then the Buddhist year is used. |
| VAR_CALENDAR_GREGORIAN | If set the Gregorian year is used. |
| VAR_FOURDIGITYEARS | Use 4-digit years instead of 2-digit years. |
| VAR_TIMEVALUEONLY | Omits the date portion of a VT_DATE and returns only the time. Applies to conversions to or from dates. |
| VAR_DATEVALUEONLY | Omits the time portion of a VT_DATE and returns only the date. Applies to conversions to or from dates. |
The COleDateTime as a formatted string.
Returns the date/time the of this COleDateTime object as a DBTIMESTAMP data structure.
FUNCTION GetAsDBTIMESTAMP (BYREF dbts AS DBTIMESTAMP) AS BOOLEAN
| Parameter | Description |
|---|---|
| dbts | A reference to a DBTIMESTAMP structure to receive the converted date/time value from the COleDateTime object. |
TRUE or FALSE.
Returns the date/time the of this COleDateTime object as a SYSTEMTIME data structure.
FUNCTION GetAsSystemTime (BYREF sysTime AS SYSTEMTIME) AS BOOLEAN
| Parameter | Description |
|---|---|
| sysTime | A reference to a SYSTEMTIME structure to receive the converted date/time value from the COleDateTime object. |
TRUE or FALSE.
Returns the date/time the of this COleDateTime object as a UDATE structure.
FUNCTION GetAsUdate (BYREF ud AS UDATE) AS BOOLEAN
TRUE or FALSE.
Returns the current date/time value in local time.
FUNCTION GetCurrentTime () AS COleDateTime
The current date/time as a COleDateTime.
DIM ct AS COleDateTime = COleDateTime().GetCurrentTime()
--or--
DIM ct AS COleDateTime
ct = ct.GetCurrentTime()
Returns the day represented by this date/time value. Valid return values range between 1 and 31.
FUNCTION GetDay () AS WORD
Returns the day of the week represented by this date/time value. Valid return values range between 1 and 7, where 1=Sunday, 2=Monday, and so on.
FUNCTION GetDayOfWeek () AS WORD
Returns the day of the year represented by this date/time value. Valid return values range between 1 and 366, where January 1 = 1.
FUNCTION GetDayOfYear () AS WORD
Returns the hour represented by this date/time value. Valid return values range between 0 and 23.
FUNCTION GetHour () AS WORD
Returns the current date/time value in local time.
FUNCTION GetLocalTime () AS COleDateTime
Returns the minute represented by this date/time value. Valid return values range between 0 and 59.
FUNCTION GetMinute () AS WORD
Returns the month represented by this date/time value. Valid return values range between 1 and 12.
FUNCTION GetMonth () AS WORD
Returns the second represented by this date/time value. Valid return values range between 0 and 59.
FUNCTION GetSecond () AS WORD
Gets the status (validity) of a given COleDateTime object.
FUNCTION GetStatus () AS BOOLEAN
Returns the current date/time value in Coordinated Universal Time (UTC).
FUNCTION GetSystemTime () AS COleDateTime
Returns the year represented by this date/time value. Valid return values range between 100 and 9999, which includes the century.
FUNCTION GetYear () AS WORD
Sets the date of this COleDateTime object.
FUNCTION SetDate (BYVAL nYear AS WORD, BYVAL nMonth AS WORD, BYVAL nDay AS WORD)
| Parameter | Description |
|---|---|
| nYear / nMonth / nDay | Indicates the date values to be copied into the COleDateTime object. |
Sets the date and time of this COleDateTime object.
FUNCTION SetDateTime (BYVAL nYear AS WORD, BYVAL nMonth AS WORD, BYVAL nDay AS WORD, _
BYVAL nHour AS WORD, BYVAL nMin AS WORD, BYVAL nSec AS WORD)
| Parameter | Description |
|---|---|
| nYear / nMonth / nDay / nHour / nMin / nSec | Indicates the date and time values to be copied into the COleDateTime object. |
Sets the status (validity) of a given COleDateTime object.
FUNCTION SetStatus (BYVAL nStatus AS BOOLEAN)
| Parameter | Description |
|---|---|
| nStatus | TRUE or FALSE. |
Sets the time of this COleDateTime object.
FUNCTION SetTime (BYVAL nHour AS WORD, BYVAL nMin AS WORD, BYVAL nSec AS WORD)
| Parameter | Description |
|---|---|
| nHour / nMin / nSec | Indicates the time values to be copied into the COleDateTime object. |
All these constructors create new COleDateTimeSpan objects initialized to the specified value.
CONSTRUCTOR COleDateTimeSpan
CONSTRUCTOR COleDateTimeSpan (dblSpanSrc AS DOUBLE)
CONSTRUCTOR COleDateTimeSpan (BYVAL lDays AS LONG, BYVAL nHours AS LONG, BYVAL nMins AS LONG, BYVAL nSecs AS LONG)
| Parameter | Description |
|---|---|
| dblSpanSrc | The number of days to be copied into the new COleDateTimeSpan object. |
| lDays / nHours / nMins / nSecs | Indicates the day and time values to be copied into the new COleDateTimeSpan object. |
The status of the new COleDateTimeSpan object is set to valid.
Returns the underlying DATE value from this COleDateTimeSpan object.
OPERATOR CAST () AS DOUBLE
Assigns a value to a COleDateTimeSpan object.
OPERATOR LET (BYVAL dblSpanSrc AS DOUBLE)
| Parameter | Description |
|---|---|
| dblSpanSrc | The number of days to be copied into the COleDateTimeSpan object. |
Adds, subtracts or compares COleDateTimeSpan objects.
OPERATOR + (BYREF dateSpan1 AS COleDateTimeSpan, BYREF dateSpan2 AS COleDateTimeSpan) AS COleDateTimeSpan
OPERATOR - (BYREF dateSpan1 AS COleDateTimeSpan, BYREF dateSpan2 AS COleDateTimeSpan) AS COleDateTimeSpan
OPERATOR - (BYREF dateSpan AS COleDateTimeSpan) AS COleDateTimeSpan
OPERATOR += (BYREF dateSpan AS COleDateTimeSpan)
OPERATOR -= (BYREF dateSpan AS COleDateTimeSpan)
OPERATOR = (BYREF dateSpan1 AS COleDateTimeSpan, BYREF dateSpan2 AS COleDateTimeSpan) AS BOOLEAN
OPERATOR <> (BYREF dateSpan1 AS COleDateTimeSpan, BYREF dateSPan2 AS COleDateTimeSpan) AS BOOLEAN
OPERATOR < (BYREF dateSpan1 AS COleDateTimeSpan, BYREF dateSpan2 AS COleDateTimeSpan) AS BOOLEAN
OPERATOR > (BYREF dateSpan1 AS COleDateTimeSpan, BYREF dateSpan2 AS COleDateTimeSpan) AS BOOLEAN
OPERATOR <= (BYREF dateSpan1 AS COleDateTimeSpan, BYREF dateSpan2 AS COleDateTimeSpan) AS BOOLEAN
OPERATOR >= (BYREF dateSpan1 AS COleDateTimeSpan, BYREF dateSpan2 AS COleDateTimeSpan) AS BOOLEAN
Retrieves the day portion of this date/time-span value. The return values from this function range between approximately – 3,615,000 and 3,615,000.
FUNCTION GetDays () AS LONGINT
Retrieves the hour portion of this date/time-span value. The return values from this function range between – 23 and 23.
FUNCTION GetHours () AS LONGINT
Retrieves the minutes portion of this date/time-span value. The return values from this function range between – 59 and 59.
FUNCTION GetMinutes () AS LONGINT
Retrieves the seconds portion of this date/time-span value. The return values from this function range between – 59 and 59.
FUNCTION GetSeconds () AS LONGINT
Gets the status (validity) of a given COleDateTimeSpan object.
FUNCTION GetStatus () AS BOOLEAN
Retrieves this date/time-span value expressed in days.
FUNCTION GetTotalDays () AS LONGINT
Retrieves this date/time-span value expressed in hours.
FUNCTION GetTotalHours () AS LONGINT
Retrieves this date/time-span value expressed in minutes.
FUNCTION GetTotalMinutes () AS LONGINT
Retrieves this date/time-span value expressed in seconds.
FUNCTION GetTotalSeconds () AS LONGINT
Sets the date and time of this COleDateTimeSpan object.
FUNCTION SetDateTimeSpan (BYVAL lDays AS LONG, BYVAL nHours AS LONG, BYVAL nMins AS LONG, BYVAL nSecs AS LONG)
| Parameter | Description |
|---|---|
| lDays / nHours / nMins / nSecs | Indicates the day and time values to be copied into the COleDateTimeSpan object. |
The status of the new COleDateTimeSpan object is set to valid.
Sets the status (validity) of a given COleDateTimeSpan object.
FUNCTION SetStatus (BYVAL nStatus AS BOOLEAN)
| Parameter | Description |
|---|---|
| nStatus | TRUE or FALSE. |